package com.orangeforms.webadmin.app.service.impl;

import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.orangeforms.common.core.annotation.MyDataSource;
import com.orangeforms.webadmin.app.dao.*;
import com.orangeforms.webadmin.app.model.*;
import com.orangeforms.webadmin.app.service.*;
import com.github.pagehelper.Page;
import com.orangeforms.webadmin.config.DataSourceType;
import org.springframework.stereotype.Service;
import com.orangeforms.common.core.base.service.BaseService;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import com.orangeforms.common.core.base.dao.BaseDaoMapper;
import org.springframework.transaction.annotation.Transactional;
import com.orangeforms.common.core.util.MyModelUtil;
import cn.hutool.core.collection.CollUtil;
import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper;
import com.orangeforms.common.core.object.MyRelationParam;

import java.util.List;

/**
 * 组织机构主数据(MdmDataOrganize)服务实现类
 *
 * @author makejava
 * @since 2022-09-05 17:24:58
 */
@Slf4j
@Service("mdmDataOrganizeService")
@MyDataSource(DataSourceType.MTM)
public class MdmDataOrganizeServiceImpl extends BaseService<MdmDataOrganize, Long> implements MdmDataOrganizeService {

    @Autowired
    private MdmDataOrganizeMapper mdmDataOrganizeMapper;
    
    /**
     * 返回当前Service的主表Mapper对象。
     *
     * @return 主表Mapper对象。
     */
    @Override
    protected BaseDaoMapper<MdmDataOrganize> mapper() {
        return mdmDataOrganizeMapper;
    }
    
    /**
     * 保存新增对象。
     *
     * @param mdmDataOrganize 新增对象。
     * @return 返回新增对象。
     */
    @Transactional(rollbackFor = Exception.class)
    @Override
    public MdmDataOrganize saveNew(MdmDataOrganize mdmDataOrganize) {
        mdmDataOrganizeMapper.insert(this.buildDefaultValue(mdmDataOrganize));
        return null;
    }
    
     /**
     * 利用数据库的insertList语法，批量插入对象列表。
     *
     * @param mdmDataOrganizeList 新增对象列表。
     */
    @Transactional(rollbackFor = Exception.class)
    @Override
    public void saveNewBatch(List<MdmDataOrganize> mdmDataOrganizeList) {
        if (CollUtil.isNotEmpty(mdmDataOrganizeList)) {
            mdmDataOrganizeList.forEach(this::buildDefaultValue);
            mdmDataOrganizeMapper.insertList(mdmDataOrganizeList);
        }
    }

    /**
     * 更新数据对象。
     *
     * @param mdmDataOrganize         更新的对象。
     * @param originalMdmDataOrganize 原有数据对象。
     * @return 成功返回true，否则false。
     */
    @Transactional(rollbackFor = Exception.class)
    @Override
    public boolean update(MdmDataOrganize mdmDataOrganize, MdmDataOrganize originalMdmDataOrganize) {
        MyModelUtil.fillCommonsForUpdate(mdmDataOrganize, originalMdmDataOrganize);
        // 这里重点提示，在执行主表数据更新之前，如果有哪些字段不支持修改操作，请用原有数据对象字段替换当前数据字段。
        UpdateWrapper<MdmDataOrganize> uw = this.createUpdateQueryForNullValue(mdmDataOrganize);
        return mdmDataOrganizeMapper.update(mdmDataOrganize, uw) == 1;
    }

    /**
     * 删除指定数据。
     *
     * @param id 主键Id。
     * @return 成功返回true，否则false。
     */
    @Transactional(rollbackFor = Exception.class)
    @Override
    public boolean remove(Long id) {
        return mdmDataOrganizeMapper.deleteById(id) == 1;
    }

    /**
     * 获取单表查询结果。由于没有关联数据查询，因此在仅仅获取单表数据的场景下，效率更高。
     * 如果需要同时获取关联数据，请移步(getMdmDataOrganizeListWithRelation)方法。
     *
     * @param filter  过滤对象。
     * @param orderBy 排序参数。
     * @return 查询结果集。
     */
    @Override
    public List<MdmDataOrganize> getMdmDataOrganizeList(MdmDataOrganize filter, String orderBy) {
        return mdmDataOrganizeMapper.getMdmDataOrganizeList(filter, orderBy);
    }

    /**
     * 获取主表的查询结果，以及主表关联的字典数据和一对一从表数据，以及一对一从表的字典数据。
     * 该查询会涉及到一对一从表的关联过滤，或一对多从表的嵌套关联过滤，因此性能不如单表过滤。
     * 如果仅仅需要获取主表数据，请移步(getMdmDataOrganizeList)，以便获取更好的查询性能。
     *
     * @param filter 主表过滤对象。
     * @param orderBy 排序参数。
     * @return 查询结果集。
     */
    @Override
    public List<MdmDataOrganize> getMdmDataOrganizeListWithRelation(MdmDataOrganize filter, String orderBy) {
        List<MdmDataOrganize> resultList = mdmDataOrganizeMapper.getMdmDataOrganizeList(filter, orderBy);
        // 在缺省生成的代码中，如果查询结果resultList不是Page对象，说明没有分页，那么就很可能是数据导出接口调用了当前方法。
        // 为了避免一次性的大量数据关联，规避因此而造成的系统运行性能冲击，这里手动进行了分批次读取，开发者可按需修改该值。
        int batchSize = resultList instanceof Page ? 0 : 1000;
        this.buildRelationForDataList(resultList, MyRelationParam.normal(), batchSize);
        return resultList;
    }

    @Override
    public void getMdmDataOrganizeListLike(String mdmOrgName,String orderBy) {
        QueryWrapper<MdmDataOrganize> qw = new QueryWrapper<>();
        qw.last(orderBy);
        List<MdmDataOrganize> organizeList = this.list(qw);
        for(MdmDataOrganize orgName:organizeList){
            log.info("打印查询结果:{}--{}",mdmOrgName,orgName.getOrgName());
        }
    }
    
    private MdmDataOrganize buildDefaultValue(MdmDataOrganize mdmDataOrganize) {
        MyModelUtil.fillCommonsForInsert(mdmDataOrganize);
        return mdmDataOrganize;
    }
}

